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CODE ASSIGNMENT IN A CDMA WIRELESS SYSTEM 

This application claims the benefit of U.S. Provisional Application Serial No. 
60/137462, filed June 4, 1999. 

5 

Field of the Invention 

The present invention relates generally to code division multiple access (CDMA) 
wireless communication systems. More particularly, the present invention relates to 
code assignments in CDMA wireless communication systems. 

10 

Background of the Invention 

Wireless communication systems in which wireless terminals (e.g. fixed or 

mobile) communicate with fixed base stations via a wireless channel are well known in 
y the art. Since the wireless spectrum bandwidth is limited, various techniques have been 

Q 1 5 developed to allow multiple wireless terminals to share the limited bandwidth. One 
:t: technique is time division multiple access (TDMA) in which wireless terminals share a 

C single frequency but are separated in the time domain v^th each wireless terminal being 

assigned a time slot. Another technique is firequency division multiple access (FDMA) in 
'^^ which wireless terminals are separated in the frequency domain, with each vidreless 

m 20 terminal being assigned a particular frequency. 

S The present invention is concemed with another technique for sharing limited 

spectrum, namely code division multiple access (CDMA). In a CDMA system, the 
signals of all wireless terminals share a frequency band and are sent together in time. 
The signals of different wireless terminals are differentiated using codes. Each wireless 
25 terminal is assigned a unique code (5) (also known as a spreading code or signature). 
The signal (d) transmitted from a particular wireless terminal to the base station is 
combined with the wireless terminal's unique code S to generate an encoded signal over a 
wide band of frequencies. If there are ^wireless terminals (1, 2, ... iQ, the signal ofthe 

I^^ wireless terminal is represented as {df^Q)} and the code of the v^reless terminal is 
30 represented as Sj^ . The transmitted signal for the k^^ wireless terminal at the zth time 

instant is represented as df^ (i)S^ . Thus, the combined signal for all the wireless terminals 
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received at the base station is (i)S^ +• • --^-d^. (i)S^ . The codes are ideally designed to be 
orthogonal such that the signal of the kth wireless terminal may be extracted at the base 
station by multiplying the received signal v^ith the wireless terminal's unique code . 
Signals originating at the base station are also combined with a code prior to being 
5 transmitted to each wireless terminal. Upon receipt of the signals, the wireless terminal 
extracts the signals from the base station by multiplying its received signal by appropriate 
codes. CDMA technology is well knovm in the art of wireless communications and will 
not be described in further detail herein. 

One problem with CDMA systems is inter-user interference (also knovm as 
1 0 multiple access interference (MAI)) which results from the leakage of signals of one 
wireless terminal into the signal of another wireless terminal This leakage is due to 
several factors. First, there is multipath propagation which results in the same signal 
IS being propagated along multiple paths with different time delays. Moreover, the codes 

;^ are usually not perfectly orghogonal in order to be able to acconmiodate a large number 

iJ 15 of terminals. Thisnon-perfectorthogonality itself also contributes to inter-user 
m interference. Also, received signals may not all be perfectly synchronized in time, which 

^ also contributes to the inter-user interiference. 

n In order to deal vdth the mterference problem, current systems generally perform 

complex operations at the receiver in an attempt to remove this unwanted interference. 

W 20 One approach of dealing with interference is single user processing, in which a receiver 
uses only knowledge of a single signal (e.g. the signal associated vdth a single wireless 
terminal) to process the incoming signal. A more sophisticated approach is multi-user 
processing, wherein the receiver uses knowledge of all signals in order to demodulate 
them all in a joint fashion. This multi-user appraoch is generally only performed at base 
25 stations because of the significant processing overhead which it requires. 
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Summary of the Invention 

We have realized that the interference experienced by a wireless terminal 
in a CDMA wireless commimication system is a result of a synergy between the code 
assigned to the wireless terminal and the particular wireless channel through which the 
5 signals of the wireless terminal pass. Thus, a wireless terminal signal propagating 

through a particular wireless channel will experience different interference with different 
codes. 

In accordance with the invention, codes in a CDMA wireless communication 
system are assigned based on characteristics of the tireless channels. By coordinating the 
10 assignment of codes among the wireless terminals based on the wireless channels, the 
total interference among the vdreless terminals is reduced and performance of the overall 
wireless communication system is improved. 

In accordance with one embodiment of the invention, an iterative code 
\M optimization algorithm maintains a processing set of wireless terminals. In accordance 

u I 15 with the algorithm, v^en the codes for the wireless terminals within the processing set 
;|: are optimized, additional wireless terminals are added to the processing set and the codes 

□ for the new processing set are optimized. This continues until the processing set consists 

of all the wireless terminals in the wireless system. This technique, called sequential 
packing, is advantageous because the code assignments are more likely to converge to the 
ijj 20 optimum solution v^en the number of wireless terminals is small and the optimal code 
t assignment of a J^-wireless terminal system is likely to be similar to that of a (^-1) 

wireless terminal system. 

In accordance v^th another embodiment of the invention, during the processing of 
each processing set a technique called target wireless terminal isolation is used. Instead 
25 of updating all the codes for all the wireless terminals in the prcK^e^ing set, a i^et 

wireless terminal is chosen and its code is optimized prior to moving on to optimize the 
codes of the other wireless terminals in the processing set. This technique also speeds up 
convergence because before the convergence of the code optimization, most of the codes 
may have already achieved good orthogonal distribution. Disturbing all the codes would 
30 likely slow down the convergence speed. 
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In accordance with one embodiment of the optimization algorithm, the code of a 
target wireless terminal is assigned as follows. First, a random search of codes is 
performed in order to find a code which is an improvement over the currently assigned 
code. In one embodiment, the random search is performed by searching all available 
5 codes until an improved code is found. In an alternate embodiment, the random search is 
performed by searching a subset of all available codes for the best code in the subset. A 
performance analysis of these random search techniques is described in the detailed 
description. The new code found by the random search is then improved by performing a 
gradient search of codes. In accordance with this technique, the signal space which 
1 0 surrounds the new code is searched in order to further optimize the code for this wireless 
terminal. This gradient search of codes may be performed by searching the codes which 
result from making a small change to the code found by the random search. The new 
:i code found by the random search may also be improved by performing a gradient search 

W of transmission delays. In accordance with this technique, the delay of transmission of 

i ji 1 5 the new code is adjusted by a small amount in order to determine the optimum delay of 
:C the code. 

Q The invention provides advantages over the prior art systems. Interference is 

n reduced at the outset by the assignment of codes based on chaimel characteristics, rather 

'^"^ than randomly assigning codes at the outset and trying to remove the interference at the 

W 20 receiver. This substantially simplifies receiver processing. 

'% These and other advantages of the invention will be apparent to those of ordinary 

skill in the art by reference to the following detailed description and the accompanying 
drawings. 

25 Brief Description of the Drav^ings 

Fig. 1 shows a system in accordance with one embodiment of the invention; 

Fig. 2 is a flowchart of the steps performed to assign codes to v^reless terminals 
in accordance v^th one embodiment of the invention; 

Fig. 3 is a graph showing the minimum SINK distribution in an example system; 
30 Fig, 4 is a graph shoving the top 2 percent performance of Fig. 3; 
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Fig. 5 is a graph showing the improvement of the probabiUty density function of 
the minimum SINR using a first search strategy; 

Fig. 6 is a graph showing the number of search cycles required to reach certain 
performance levels; and 
5 Fig. 7 is a graph showing the improvement of the probability density function of 

the minimum SINR using a second search strategy. 

Detailed Description 

A system in accordance with one embodiment of the present invention is shown 
10 in Fig. 1 . Wireless terminals 1 lOu 1 IO2, . . . 1 10a: are communicating with base station 
102 in accordance with the CDMA communication protocol Broken line 104 represents 
a logical separation between forward link (i.e., base station to wireless terminals) 
^3 components above the broken line 104 and reverse link (i.e., vrireless terminals to base 

Q station) components below the broken line 104. Base station 102 comprises antennas 

15 IO61, IO62, ... 106p for receiving signals from the wireless terniinals 110, Aftequency 
=f down converter 1 12 receives the signals from the wireless terminals 1 1 0 and demodulates 

Q the signals to extract baseband signals. Thus, the output of frequency downconverter 1 12 

is the combined baseband signal from all wireless terminals K^^d^ (i)S^ +• • -^K^^^df. (i)S , 
: f where k . is the combined effect of the wireless channel of the kth terminal and the pth 

:i 20 antenna element. Note that the signal model used herein does not assume intersymbol 
0 interference (ISI), but one skilled in the art could readily extend the model to inciiKie ISL 

The combined signal is provided to a joint channel estimator i 14 and a space-time 
matched filter 116. The joint channel estimator 114 receives the baseband signal and 
determines the characteristics of the wireless channels k^^ over which the signals have 

25 been received. 

The wireless channel is described by a multi-path propagation model. A 
mathematical description of the model which provides a basis for a further description of 
the elements of Fig, 1 will now be given. In large cells v^th high base station antenna 
platforms, the propagation channel comprises a few dominant specular paths. In such a 

30 case, the baseband signal received by the base station 102 can be expressed as follows: 
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xW = i t afe,/K/WJ'.(^-^w)+nW (1) 

where x(r)is the received baseband signal as a function of time t; n{t) is the additive 
noise; K is the number of wireless terminals visible to the base station 102; L is the 
maximxnn number of propagation paths present in the system for each wireless terminal; 
5 a(^jt ; ) is the steering vector of wireless terminal A: to a signal arriving from direction ; 
/ is the complex time-varying amplitude of the path of the Jd^ wireless terminal, 
with the path amplitude being a complex Gaussian random proce^ including both the 
propagation loss and the signal fading caused by the Doppler spread; is the transmitted 
complex baseband signal from the k^^ wireless terminal; r^^ j is the propagation delay of 

1 0 the /^^ path of the k!^ wireless terminal. 

In a CDMA system with the length of the spreading code N equal to the number 
of chips in a symbol period, the transmitted signal s' can be represented as the 
convolution of the data bits, the codes and the pulse-shaping function. Assuming band- 
limited signals in the system, if each continuous signal is sampled at a rate which is 

1 5 higher than twice the Nyquist rate, then the convolution, correlation, and integration 
operations can be replaced by multiplication of matrices with appropriate arrangements 
of matrix elements from the sampled data. In the present embodiment, we assume P 
antennas, and we oversample the signals with a factor of p (i.e., we sample the signal p 
times in each chip). In addition, there are N chips in each data symbol, and M data 

20 symbols are considered. We also assume that the maximum path delay plus the length of 
the pulse-shaping function is no greater than QTc and that Q<N, where Tc is the chip 
period (if Q is much smaller than N, then the system is quasi-synchronous). After 
sampling, we can express the received signal X as 

X = |;A,B,GAD.+N (2) 

25 where X: P x MNp and N: x MNp are, respectively, the received signal and the 
additive Gaussian noise; A^:PxL is given by 

A^k =Wk,M^k,2)-M&k,L)l B,:Ix I is given by B, =diag{^, } with 
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fi^ ;eindthe i/^ QlQmmtof G^:LxQp can be written as 

?(^o ~ — " T'c^^ki) ^th g(.) being the normalized pulse-shaping function. The code 
P 

matrix : x ( + ^ - 1)/? is a Toeplitz matrix with {s^^ ^ S^u{Qp-\) f its first column, 
and [Sj,^xA.{p-iihaKip~xy'-^S^,,fi^^^ as its first row, where s,^,,s^2,,.,,s^,, is the 
5 normalized code of the wireless terminal. The data matrix li^\{N -^Q-\)px MNp is 
also a Toeplitz matrix with [^jt,/«-pOix(iv/>-i)5^A,m-pOix((Q-i)p-i)]^ as its first column, and 
{dkiKiNp-^)A,n^.xA.iNp-^v^^^^ as its first row, ^ere {d^J are the 

binary phase shift keying (BPSK) data bits of the li^ wkeless terminal 

In addition, the temporal signature matrix Sj^: I x (iV + g - 1)/? is defined as 

10 Sjt = GjtSjt . The f row of Sj^ denotes the temporal signature of the f path of the h!^ 
wireless terminal seen at the receiver. Similarly, the column of denotes the spatial 
signature of the path of the 1^ wireless terminal. If we consider the impulse response 
of the wireless channel, and assume there is only one symbol transmitted for each 
wireless terminal, then Dk equals times an identity matrix. After stacking the 

1 5 columns of X, equation (2) can be written as 

vec(X) = f^d,,(SloA,)j3, (3) 
= t ® ^*,/) + vec(N) (4) 

k^X l=X 

where the "vec" operator stacks columns of a matrix putting them one below another, ® 
denotes the Kronecker product, o denotes the Khatri-Rao prodiict (column-wise 

20 Kronecker product), and S^^^ , is the f row of 5^ . Thus, Sj^j ® ii(0k,i) is the space-time 
signature of the path of the A:^^ wneless terminal. If there is more than one symbol 
transmitted for each wireless terminal, inter-symbol interference results in space-time 
signatures overlapped in time within the received signal X. 

Returning now to Fig. 1, the joint channel estimator 1 14 receives the baseband 

25 signal and, using the above described model, determines characteristics of the channels of 
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the wireless terminals 1 10. Channel information including the path DO As (direction of 
arrival) { ^ }, the propagation delays { , }, and the complex path fading amplitudes 
{ , } are required in the space time matched filter 1 16, the signal detector 120, and the 
code optimizer 118. The joint channel estimator 1 14 determines these channel 
5 characteristics as follows. 

The joint channel estimator 1 14 estimates the path DOAs (^^ i) and the 

propagation delays (r^ i) by using known subspace-based algorithms. Appropriate 
subspace-based algorithms which may be used by the joint channel estimator 1 14 are 
described in, M. C. Vanderveen, C. B. Papadias, and A. Paubraj, Joint Angle and Delay 
1 0 Estimation (JADE) for Multi-Path Signals Arriving at an Antenna Array, IEEE 

Communications Letters, vol. 1, no. 1, pp. 12-14, Jan. 1997. Since both the path DOAs 
Q and the propagation delays usually remain unchanged over a long period of time, the 

id above referenced subspace-based algorithms may be used in order to obtain accurate 

1=1 chaimel estunations. For purposes of this description, it is assumed that we have perfect 

=i 1 5 information on the path DOAs and the propagation delays as a result of one of the above 
n referenced algorithms. With the path DOAs and propagation delays available, { } can 

;L be reconstructed by using the array manifold a(.) and {Gjt} can be reconstructed by using 

M the temporal manifold g(.). Note that {S^} denotes the wireless terminal codes, which are 

id known to the base station 102. The only remaining unknowns left in equation (2) are 

5 20 {B;t} and {D^} , which are the complex path fading amplitudes and the transmitted data 
symbol matrix respectively. The data symbol matrix can be obtained by using known 
training sequences or in a decision-directed fashion, i.e., the demodulated data symbols 
can be easily used as training data. To estimate {B*} , we can re- write equation (2) as 
X = [Ai, A2, ...,Ax]diag(Bi,B2, ...,Bic)diag(Gi, G2, ...,Gk) 
25 diag(S,,S2,...,SJ,)[Dfl,D2^...,D^]^+N (5) 

= ABGSD + N, (6) 
where A = [Ai, A2, . . ., A*:]; B = diag(Bi, B2, . . ., B*:); G = diag(Gi, G2, . . ., G^:); 
S = diag(Si,S2,...,Sif);andD = [D[l,D[,...,D^]^ The least square criterion is used 
to estimate the fading amplitudes hatj3 as 
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=((GSDf oA)\ec(X) (7) 

where ^ = with fi^ being the least square estimate of ; and (.) ^ 

denotes the pseudo-inverse. 

The channel estimates calculated by the joint channel estimator 1 14 are provided 
5 to space-time matched filter 1 16, code optimizer 1 18, and signal detector 120. 

The space-time matched filter 1 16 is used to obtain sufficient statistics for 
demodulating the digitally modulated signals. The output of the space-time matched 
filter 1 1 6 may be written as 

X,^=ReMB;A;X'"S;}}. (8) 

10 Where "tr" denotes the trace of a matrix, and X" : P x {N + Q-l)p is copied from the 
((m -\)np+ if to [mNp + Qpf columns of X The matrix multiplication of A^ and 
denotes the path-wise beam-forming. Let X^ „ = A'X" . The ti^ce of the matrix 
'f\ multiplication Xi { B jX^ ^S^ } denotes the matched filter for the temporal signaUire and 

% the maximum-ratio path combining of the k'' wireless terminal. To expand X^^ „ 

T'' 1 5 equation (8) can be rewritten as 

3 X,^ =gRe{/r{B;A;A,B,S,Drs:}} + Re{/r{B;A;N'"S:}} (9) 

% where and D " are tiie sub-matrices of N and Di respectively, so X" is constructed 

fi:om X. Note that is a Toeplitz square matrix with [di^n,,^u(Np-ir^i^-\,^\>^m-\)P-^ )1 

as its first column, and [d>^,K(>,p-^)A,n,-^K((Q-^)p-^ )] ^ '^^ row. Therefore, the 
20 first term on the right hand side of equation (9) can be written as 
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= t ReK,„/,((A;A,) 0 iS,Siy)fi. 4-^f,,„.X({A;A,) 0(S,(+1)S:(-1))^)A 

+ d,^..A((K^,) © (s,(-i)sI(+i))^)A}, (10) 

where O denotes the Hadamard product or the entry-wise product, S^C+l) and S^(-l) 
are both sub-matrices of S^. The rightmost and the left most (g-l)/? columns are 
respectively denoted by S/^i+l) and S^(-l). For additional information on the 
Hadamard product/entry-wise product, see Roger A. Hum and Charles R. Johnson, 
Topics in Matrix Analysis, Cambridge University, Press 1991. 

We can stack the matrices and write the received signal at the output of tiie space- 
time matched filter 1 16 as 

X= i'd+N, 

(11) 

where X = [X,,, X2,„...,X^,, X, 2,...,XJ,,A^]^d = [d,^id,i,...,d^^d,2,...di,j^f,and 

N = [N,,,N3,,,...,N^,,N,2,...,N^,m]' with N,^ = Re{/r{B;A;N'"S;}}. If we define 

H(0): 

KxK, H(+l): ^ X and H(-l): X ^ as 

H(0) = B*((A*A) 0 (SS*)^)B^ (12) 

H(+l) = B*((A*A) O (S(+1)S*(-1))")B, (13) 
H:-r)=B*((A*A)o (S(-l)r(+l))^)B (14) 

with 

A = [A,A,,...,AJ,S = [Sf,S[,...,S^]^S(+l) = [Sf(+l),S;(+l),...,^ 
S(-1) = [S[(-1),S[(-1),...,S^)(-1)]^ 
and define the fading amplitude matrix B:A:Zx^asB = diag ( {Pxfi2,.-,fi k) ' then 
can be expressed as 
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T=Re{ 



H(0) H(-l) 
H(+l) H(0) H(-l) 
H(+l) H(0) 

0 



0 

H(-l) 

H(+l) H(0) 



(15) 



The output of the space-time matched filter 1 16 is provided to the signal detector 
120. The signal detector 120 also receives the channel estimations from the joint channel 

5 estimator 1 14 and the codes which are output from the code optimizer 118. We assume 
that only Ko in-cell wireless terminals need to be demodulated at the base station 102. 
Therefore, only the space time matched filter 1 16 outputs related to these Ko vdreless 
terminals are processed in the signal detector 120. We now describe three possible 
embodiments of the signal detector 120. 

1 0 First, signal detector 120 may be unplemented as a single wireless terminal 

detector. In this embodiment Ko slicers are used at each output of the space-time matched 
filter 116. Decisions are instantaneous with no delay. The data estimate is given by 

d,^^ = sgn(X,,J, (16) 
where „ is the output of the space time matched filter 1 16 in equation (8). 

15 In a second embodiment, signal detector 120 may be unplemented as a decorrelator. In 
this embodiment, a zero-forcing solution is applied to solve equation (1 1). The data 
estimate can then be written as 

d = rx. (17) 

In a third embodiment, signal detector 120 may be implemented as a minimum mean 
20 square error (MMSE) detector. This embodiment generally performs better than the zero- 
forcing solution of the decorrelator in the second embodiment, when taking into account 
the effect of the correlated noise. The coloring matrix of the noise, N in equation (11), 
at the output of the space time matched filter 1 16 is given by: 

E(m') = ^n (18) 
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The data estimate for the MMSE detector can then be expressed as 

d= /(icf +-i^r'x, (19) 

E 

where ai denotes the noise variance chosen to match the desired — with being the 

bit energy and Nq being the average noise variance, and cr^ = 1 for the BPSK 
modulation scheme. It is noted that in both the decorrelator and the MMSE detector 
embodiments, the maximum possible delay could be up to M symbols because of the 
block processing of the asynchronous signals. The reverse link data outputs of the signal 
detector 120 may be provided to, for example, a telephone network node such as a 
switch. 

In accordance with the invention, the base station 102 includes a code optimizer 
118 for assigning codes to wireless terminals. The steps performed by the code optimizer 
1 18 will be described in conjunction with the flowchart of Fig. 2. In one embodiment, 
the code optimizer 118 is implemented using a computer processor executing stored 
computer program code. Thus, the code optimizer operates under control of the 
processor executing stored computer program code. The computer program code defines 
the steps described herein in conjunction with the flowchart of Fig. 2. Given the 
description contained herein, one skilled in the art could readily implement the code 
optimizer 1 18 in other ways. For example, the code optimizer 118 could also be 
implemented using hardware, or some combination of hardware and software. 

The steps shown in the flowchart of Fig. 2 are performed by the code optimizer 
1 18 in order to optimize the codes assigned to the wireless terminals communicating with 
the base station 102. In step 202, as processing set is mitialized with one of the wireless 
terminals. In step 204 a target wireless terminal is chosen from the processing set. If 
step 204 is executed immediately following step 202, then there will only be one wireless 
terminal in the processing set and that wireless terminal will be chosen as the target 
wireless terminal. In step 206 a random code search is performed for the wireless 
terminal chosen as the target in step 204. The random code search is performed in order 
to try to improve the current code assigned to the target wireless terminal by attempting 
to reduce the interference experienced by the target wireless terminal. 
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One way to suppress the mutual interference among the wireless terminals is to 
maximize the minimum signal to interference-plus-noise ratio (SINR) among in-cell 
wireless terminals, where 

^™„=,min^4. (20) 

5 The SINR of the wireless terminal can be written as the power ratio of the signal 
and the interference-plus-noise: 

— (21) 

The signal power ^^'.Kxl can be written as 

= diagiUm © co«7(diag(H(0)), (22) 

10 where H(0) is given in equation (12), "conj" is the complex conjugate operation, and the 
output of diag(.) is a column vector consisting of the diagonal elements of the argument 
matrix. The interference power ^jiKxl can be vmtten as 

^j^diag(mi')-4s. (23) 
where H = [H(-1),H(0),H(+1)], and H(0), H (+1), and H(-l) are given in equations 
15 ( 1 2), ( 1 3) and ( 1 4) respectively. The noise power : Kxl can be written as 

^^=^c//ag(H(0)). (24) 

Note that in using the minimum SINR as the criteria for code optimization, two factors 
are taken into consideration: 1) the received power of each wireless terminal at the base 
station, and 2) the orthogonality among codes. 

20 Although some out-of-cell wireless termmals may generate interference with 

respect to in-cell wireless terminals we assume that the only visible wireless terminals are 
in-cell wireless terminals such that K-K^, For systems with a high frequency re-use 
factor this is a reasonable assumption. 

We now return to step 206 of Fig. 2 in which the code optimizer 118 performs a 

25 random code search. The less dense regions of the signal space must be explored in order 
to maximize the distances between the wireless terminal codes. More particularly, we 
need to adopt some of the im-used codes by random search in order to span the entire 
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signal space. It is also noted that a good code for one wireless terminal may not 
necessarily be a good code for another wireless terminal because the wireless channel of 
each wireless terminal is different. Therefore, a random-searching procedure of codes is 
required for each wireless terminal in order to cover those less dense areas in the signal 

5 space. When the number of wireless terminals is small compared to the dimension of the 
signal space, it is easier to find a less dense area by random searching. Otherwise, longer 
searching may be required. We now describe two alternate techniques for performing the 
random code search step 206. The first technique is to continue searching all the possible 
codes until a better code is obtained. If the number of wireless terminals is large 

1 0 compared to the dimension of the signal space, it may take a long time to find a better 
code. The second technique is to only search a subset of randomly-picked codes, and 
choose the best code in the subset if it is better than the original code prior to the random 
search. If the number of wireless terminals is small compared to the dimension of the 
signal space, the second approach might require a large amount of unnecessary searching. 

1 5 However, if the number of wireless terminals is large compared to the dimension of the 
signal space, this second technique might stop at a sub-optimal value. One skilled in the 
art would recognize that other techniques could be used to implement the random code 
search. 

Although it is unlikely that the best code will be found by the random search step 
20 206, the best available code is likely to be in the vicinity of the less dense area in the 
signal space which surrounds the code found in step 206. Thus, the code for the target 
wkeless terminal may be fiarther optimized by gradient-searching this less dense area in 
the signal space. 

In step 208 it is determined whether the random code search of step 206 resulted 
25 in an improvement of the SINK for the target wireless terminal. If there was an 

improvement, then in steps 210 and 220 two types of gradient searches are performed in 
order to find the best code for this wireless terminal. 

In step 210 a gradient search of codes is performed as follows. A small change is 
made to the code of the target wireless terminal to determine if there is improvement in 
30 terms of the minimum SINK. Assume the length of the code is iV chips long. N different 
codes are generated by individually changing the sign of each chip in the code. These 



14 



J-T Chen 5-8-3 



different codes are then compared with the original code. If none of the new codes 
performs better than the original code, then the gradient search of codes is considered to 
be converged. Otherwise, the original code is replaced with the best code among the 
new codes, and the same process is repeated. Note that the change of the sign of only one 
5 chip in the code results in only a minimum change of the code on the transmission side. 
It is expected that such a minimum change in direction will also result in only a minor 
change of the code as seen at the receiver. 

In step 220 a gradient search of transmission delays is performed m follows. The 
delay of transmission of the wireless terminal code is adjusted by a small step AT in 

10 order to determine the optimum delay of a specific code. Assuming band-limited signals, 
the step size AT should be in inverse proportion to the signal bandv^dth. 

As represented by step 222, the gradient search of codes (step 210) and the 
gradient search of delays (step 220) continues until no further improvement in the SINK 
for the target wireless terminal is achieved. It is determined in step 224 whether the code 

1 5 searching steps (steps 204-222) have converged. Convergence of the code search is 
defined as the condition where there is no space for further improvement regardless of 
which target wireless terminal of the processing subset is picked. Convergence may be 
determined by repeating steps 204 through 208 until there is no improvement. Eventual 
convergence is guaranteed because there are only a finite number of possible code 

20 assignments, although this finite number 2^ could be very large, where G is defined 
as the number of possible transmission delays. There are a finite number of possible 
transmission delays because of finite resolution in time for the assumed band-limited 
signals in the system. If an exhaustive search is possible, the optimum assignment is 
guaranteed. Otherwise, since we are constantly looking for a better minimum SINK, the 

25 proposed algorithm can at least converge a local optimal solution. 

Returning to Fig. 2, if the test in step 224 is no, then control returns to step 204 
and a new wireless terminal fi-om the processing set is chosen as the target wireless 
terminal and the code search of steps 206-222 are repeated. Note that the new target may 
be a wireless terminal already chosen during this processing loop. If the test in step 224 

30 is yes, then in step 226 it is determined whether the number of wireless terminals in the 
processing set equals the total number of wireless terminals commimicating with base 
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Station 102. If not, then in step 228 another wireless terminal is added to the processing 
set and steps 204 through 224 are repeated for the new processing set. If it is determined 
in step 226 that the number of wireless terminals in the processing set equals the total 
number of wireless terminals communicating with base station 102, then in step 230 the 
5 codes which are currently assigned to the wireless terminals are output from the code 
optimizer 118 and processing ends. 

Returning now to Fig. 1 , the optimized codes from code optimizer 1 1 8 are 
provided to the signal detector 120 and to the forward link moduiator 122, The forward 
link modulator 122 also receives forward link data inputs which may be, for example, 

10 telephone signals from a telephone network. The forward link modulator 122 modulates 
the forward Imk data and the codes received from the code optimizer 118 and provides 
the modulated signal to the frequency up-converter 124, The frequency up-converter 124 
transmits the signal to the wireless terminals 1 10 via antenna 126. In this manner, the 
newly assigned codes are transmitted to the v^reless terminals 110. The wireless 

1 5 terminals then use the newly assigned codes for subsequent revei^e link communication. 
As described above the signal detector 120 also receives the new codes from the code 
optimizer 1 18 so that the signal detector 120 can decode the subsequent reverse link 
communication. 

Thus, as described above in connection with one advantageous embodiment, the 
20 use of a processing set results in an iterative algorithm m which v^reless terminals are 
added into the processing subset one by one and only after the code optimization 
procedure has converged for the prior processing set. This technique, which we call 
sequential packing, is advantageous because the code assignments are more likely to 
converge to the optimum solution when the number of wireless terminals is small. 
25 Furthermore, the optimal code assignment of a J^-wireless terminal system is likely to be 
similar to that of a (J^T-l) wireless terminal system. 

Further, during the processing of each processing set, we use the technique of 
target wireless terminal isolation. Instead of updating all the codes for all the wireless 
terminals in the processing set, we isolate a target wireless terminal each time and 
30 optimize its code before moving on to optimize other wireless terminal codes. This also 
speeds up convergence because before the convergence of the code optimization, most of 
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the codes may have already achieved good orthogonal distribution. Disturbing all the 
codes would likely slow down the convergence speed. 

The following portion of the description addresses performance issues of the 
above described code assignment techniques. The performance of the algorithm 

5 described in conjunction with Fig. 2 depends on the number of wireless terminals, the 
dimension of the signal space, the overall channel of each wireless terminal, and the 
adaptation procedure used for code optimization. 

In general, there are 2^ possible code assignments, where G is defined as the 
number of possible transmission delays, K is the number of wireless terminals, and N is 

1 0 the length of a code. There are a finite number of possible transmission delays because 
of the finite resolution in time for the assumed band-limited signals in the system. The 
minimum SINK can be calculated for each code assignment. System performance is 
improved in accordance with the described technique of replacing the original random 
signature assignment with one of the best signature assignments if possible, and thus 

1 5 improve the minimum SINR. Fig. 3 shows an example of the minimum SINR 

distribution in a simple system in which we assume a synchronous system vdth only one 
path of unit gain for each wireless terminal, i.e., G = 1, a code of 4 chips long, up to 4 

E 

wireless terminals, a single antenna, and = co. Each curve in Fig. 3 is labeled by the 

number of wu-eless terminals in the system. J is defined as the total number of possible 
20 code assignments, and therefore, J = 256, 4096, and 65536, for two, three, and four 

wireless terminals respectively. In Fig. 3 the minimum SINR vs. x is plotted, where the 

minimum SINR is sorted in ascending order, x^~, mdjis the code assignment number 

afl:er sorting. Therefore, the horizontal axis of Fig. 3 represents the percentage of the 
bottom performance among all the possible code assignments. Note that the minimum 
25 SINR is very low most of the time without code assignment optimization regardless of 
the number of wireless terminals in the system. The improvement on the minimum SINR 
caused by reassigning the wireless terminal codes is very significant when the number of 
wireless terminals is close to the dimension of the signal space. When the number of 
wireless terminals is small, the improvement is still great but not as significant, because it 
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is relatively easy to separate the code vectors in the signal space. In Fig. 4, the top 2 
percent performance of Fig. 3 is expanded. In this example, we can obtain orthogonal 
codes if the algorithm of Fig, 2 converges to the minimum SINR among the top 20 
percent, top 1.5 percent and top 0.05 percent, respectively, when there are 2, 3 and 4 
5 wireless terminals in the system. 

The problem of how many searches are required to reach a specific percentage of 
the top minimum SINR performances is now addressed. The trade-off between the 
complexity of the search algorithm and the improvement on the SINR i^rfomiance is 
also investigated. Since the number of possible code assignments Vis usually a very 
10 large number, the efficiency of the code searching turns out to be an important issue. 

First, we analyze the probability of each code assignment getting picked using two basic 
strategies: 1) blindly searching all the possible codes assignments until a signature 

Q assignment with better minimum SINR is found, and 2) blindly searching Ji code 

y assignments and picking the best one. 
M 5 We estimate the approximate number of blind searches in the algorithm and then 

P compare this number to the number of blind searches required for the minimum SINR to 

reach a certain performance level. We first analyze the code assignment searching 

L. strategy in which all the possible code assignments are blindly searched until an 

y assignment which achieves a better minimum SINR than the current assignment is found. 

liJ 20 U) is defined as the probability of picking the;^ signature assignment. For a system 

ti using pseudo random codes, the probability distribution is given as 

p^(j) = — ,;■ = 1,2,..., y. Recall that the code assignments are sorted in ascending order. 
If the probability that the assignment gets picked next is 2m>, then the probability 

that any of the last J -71 assignments gets picked next is ^ . . Therefore, the 

~J\ 

25 probability distribution after the first cycle of searches {/?, (;)} becomes 

P,=Mpo, (25) 

where Po =[a(->^).A(^-1X-'/^o(1)]^Pi =[a(Aa(-^-1)— and the 
transition matrix M : J x J is defined as 
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10 



15 



M = 



1 1 i i 

2 3 

0 0 i i 

2 3 



1 



0 0 0 



0 0 0 0 
0 0 0 0 



J-1 
1 

J-1 
1 

J-1 
1 

J-1 

0 



(26) 



From observing the structure of M, it is seen that this code assignment searching 
algorithm pushes the distribution of the minimum SINR toward the better side of 
performance. To further improve the minimum SENfR, we can repeat the same searching 
strategy several times. If / search cycles are conducted, we can obtain a probability 
fimction pi given by 

P,=M'Po (27) 
Note that once a good minimum SINR has been obtained, the number of searches 
required in each search cycle increases as the searching continues, since it is getting more 
difficult to find an even slightly better minimum SINR. The average number of blind 
searches required at the i"* cycle can be written as 



7^1 J-J 



(28) 



The number of possible signature assignments J is usually a large number. Therefore, 
equations (25), (27) and (28) are difficult to evaluate. Thus we need to rewrite these 
equations in a continuous form. Let the f assignment be the bottom xQ) percent among J 

assignments, namely x = — , and let pX^) be the probability density function of x after 

J 

the search cycle. The probability density function after the first cycle of searching 
becomes 



p,(.)=js^^=/«^, 



(29) 



20 where " / «" denotes the natural log. Similarly, the probability density fimction after the 



i'^ cycle of searching becomes 
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AW-IoA-iWt^^- (30) 
By solving equation (30), we obtain 

P^{x)--Xln-^)\ (31) 
/! 1-x 

where /! denotes factorial i. The cumulative distribution function (CDF) of the minimum 
5 SINR after the cycle of searching can then be written as 

p^^Cm{x)^x-Y)^{ln^)\ (32) 

In addition, the average number of blind searches in the search cycle can be written as 

«/=1oPmW7^^- (33) 
\-x 

,^ Fig. 5 shows the improvement of the probability density function of the minimum 

10 SINR using the random search technique of searching all possible codes until a code 
'fi which is better than the current code is found. Each curve in the figure is labeled by the 
W number of the search cycles. By comparing Fig. 3 with Fig. 5, the number of cycles of 

m blind searches which are required to achieve a certain minimum SINR performance can 
be determined. Fig. 6 shows the number of blind search cycles required to reach certain 
^3 15 performance levels for the two random search techniques. Section 602 of Fig. 6 shows 
\1 the number of search cycles required to have 50, 90, and 99 percent chance for the search 

:^ results to be among the top 10, 1 and 0 J percent of performance of all possible code 

13 assignments for the first random search technique which searches until a better code is 

found. For example, to have a 90 percent chance to reach the top 1 percent of 
20 performance using the first random search technique, we need to search for a better 
assignment at least 7 times. 

As described above, the second search strategy is to randomly search through a 
fixed number of code assignments to find the code with the best minimum SINR. If we 
search through / possible code assignments, the probability of picking they^^ assignment 
25 pXj) is given by 



'^'-^forj>i 



Cy ' " . (34) 
0 forj<i 
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However, if we use i - 1 pairwise comparisons to search through i possible code 
assignments and we allow the same code assignments to repeat within i assignments, we 
can modify pXj) as follows: In each pairwise comparison, if the assignment is first 

used, there is a ^ — ^ chance that the jf assignment will be compared to an assignment 
J '~ 1 

5 with poorer minimum SINK, while there is a — ^ chance that the jf assignment will 

tJ 1 

be compared to an assignment with better minimum SINR. Therefore, the probability of 
the first j\ - 1 assignments getting picked next is zero; the probability of the same 

• and the probability of any of the better 



10 



assignment getting picked next is ■ 
assignments getting picked next is 



J-l 
1 



Thus, we can write {pj as 



J-l 

p,=M'-'po,/ = 2,3,... (35) 

where Po = [Po('^lPo(J -'^l-,Poi^)Y ^P, = [P,i'^,P.(-^ -'^%-'Pi('^)f > and the 
transition matrix M : Jx Jis defined as 

1 1 



M= 



1 



1 



J-l J-l 
J-2 1 



J-l J-l 
1 1 



J-l J-l 
J-3 



0 0 

0 0 
0 0 



J-l 

0 
0 



J-l J-l 
1 1 
J-l J-l 



1 



1 



J-l J-l 

0 0 



(36) 



1 5 Again, the structure of the matrix M shows that this code assignment searching algorithm 
pushes the distribution of the minimum SINR toward the better side of the performance. 
Because Jis usually a large number, equation (35) is not easy to evaluate. Therefore, 
is expressed in a continuous form as 

P2(x) = llPoix)dx + P(,(x)x = 2x (37) 
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assuming p^{x) = l,x €[0,1], and also 

A W - io A-i + A-i W^'^* 3,4... (38) 
By solving equation (38), we obtain 

pXx) = ix'-'^ (39) 
5 The CDF of the minimum SINR after searching through i signature assignments can then 
be written as 

p,,CDF(x)-x'. (40) 
Fig. 7 shows the improvement of the probability density functron of the minimum 
SINR using the second search strategy of searching through a fixed number of code 
10 assignments. Each curve in the figure is labeled by the number of assignments searched. 
Comparing Fig. 3 with Fig. 7, we can determine how many code assignments must be 
searched in order to achieve a certain minimum SINR performance. Section 604 of Fig. 
fl 6 shows the number of searches required to have 50, 90, and 99 percent chance for the 

\M search results to rank among top 10, 1 and 0.1 percent of performance of all possible code 

2 1 5 assignments using the second random search strategy. 
^ There is a trade-off between the minimum SINR performance and the 

r convergence speed. In the described algorithm, the convergence criterion, the step-size 

!:1 of the gradient search, and the technique of picking a target wireless terminal can be 

\^ controlled in order to adjust the algorithm complexity and convergence speed. If the 

2 20 complexity of the assignment searching procedure is increased, then the minimum SINR 
performance is expected to improve, while it might take more time for the algorithm to 
converge. This trade-off is investigated in order to determine how much increase in 
algorithm complexity is required to achieve a certain performance improvement. The 
number of equivalent blind searches n in the proposed algorithm is estimated. Based on 
25 w , and Figs. 5-7, the improvement on the minimum SINR among all the possible code 
assignments is evaluated. 

As described above, blind searches are generally inefficient regardless of the 
searching strategy used. In view of the above performance analysis, improvements for the 
searching techniques may be summarized as follows. 
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The random searches and the gradient searches serve the respective purposes of 
region dividing and local regional searching in the signal space. The random search first 
looks for the regions where a higher minimum SESfR is more Ukely to occur. This 
random search may be seen as dividing the signal space into small regions and then 
5 finding one of the best regions among other sub-optimal regions. The gradient search 
then searches for the best minimum SINR around the best local region determined by the 
random search. The number of random searches for the code of wireless terminal k is 
defined as n^^^Af the best code assignment in the best region has higher minimum SINR 
than any code assignments within those sub-optimal regions, then the equivalent number 
1 0 of blind searches for wireless terminal k can be written as 

«*=«.A*(^ + 2). (41) 

Equivalent gradient searches are assumed to be conducted for each of the sub-optimal 
regions although these gradient searches are actually omitted. Note the factor + 2 in 
equation (41) represents the number of searches in each step of the gradient search; N 

15 searches for the code, and 2 searches for the transmission delay. 

With respect to target vdreless terminal isolation and sequential packing, if the 
number of wireless terminals in the system is much less than the dimension of the signal 
space, it can be assumed that the code search for each wireless terminal is independent. 
In other words, we assimie that the best code found while searching the best codes for 

20 wireless terminal k regardless of the codes of other wireless terminal, is also the best code 
for wireless terminal k when searching the best code assignments for all the wireless 
terminals. The main purpose of the sequential packing technique described above is to 
validate this assumption. Therefore, the overall equivalent number of blind searches h in 
the algorithm is roughly given by 



K K 



25 « = n«.=nV..*(^ + 2) (42) 

The estimation of h in equation (42) is over-optimistic; however, it offers some insights 
into the relationship between the system performance and the algorithm complexity. 

The foregoing Detailed Description is to be understood as being in every respect 
illustrative and exemplary, but not restrictive, and the scope of the invention disclosed 
30 herein is not to be determined from the Detailed Description, but rather fi-om the claims 
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as interpreted according to the foil breadth permitted by the patent laws. It is to be 
understood that the embodiments shown and described herein are only illustrative of the 
principles of the present invention and that various modifications may be implemented by 
those skilled in the art without departing from the scope and spirit of the invention. 
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1 LA method for assigning codes in a CDMA wireless communication system in 

2 which a plurality of wireless terminals conmiunicate via a plurality of chanjtiels, said 

3 method comprising the steps of: 

4 determining characteristics of said plurality of channels; and 

5 assigning codes to said plurality of wireless terminals based on said 

6 characteristics of said channels. 

1 2. The method of claim 1 wherein said step of assigning codes comprises the 

2 steps of: 

3 choosing a target wireless terminal; and 

4 assigning a code to said target wireless terminal. 

1 3. The method of claim 2 wherein step of assigning a code to a target wireless 

2 terminal comprises the step of: 

3 performing a random code search to obtain an improved code for said target 

4 wireless terminal which is an improvement over a current code of said target wireless 

5 terminal. 

1 4. The method of claim 3 wherein said step of performing a random code search 

2 comprises the step of randomly searching available codes until an improved code is 

3 found. 

1 5. The method of claim 3 wherein said step of performing a random code search 

2 comprises the step of randomly searching a subset of available codes for the best code in 

3 said subset. 

1 6. The method of claim 3 further comprising the step of: 
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2 performing a gradient search of codes in the signal space area surrounding said 

3 improved code. 

1 7. The method of claim 3 further comprising the step of: 

2 performing a gradient search of transmission delays for said improved code. 

1 8, The method of claim 3 further comprising the steps of: 

2 performing a gradient search of codes in the signal space area surrounding said 

3 improved code; and 

4 performing a gradient search of transmission delays for said improved code. 

1 9. The method of claim 1 further comprising the steps of: 

2 maintaining a processing set of said plurality of wireless terminals; 

3 individually assigning codes to said wireless terminals in said processing set; and 
\m 4 adding a wireless terminal to said processing set when said step of individually 
m 5 assigning codes to said wireless terminals in said processing set has converged and 

6 repeating said step of individually assigning codes. 

\^ 1 10. The method of claim 1 further comprising the step of: 

2 transmitting said codes to said plurality of wireless terminals. 

1 1 1 . A method for assigning a code to a v^reless terminal in a CDMA wineiess 

2 commxmication system comprising the steps of: 

3 determining characteristics of a communication channel of said wireless terminal; 

4 and 

5 assigning a code to said wireless terminal based on said characteristics of said 

6 conmiunication channel. 

1 12. The method of claim 1 1 wherein said step of assigning a code further 

2 comprises the step of: 

26 



J-T Chen 5-8-3 



3 performing a random code search for an improved code relative to a current code 

4 assigned to said wireless terminal. 

1 13. The method of claim 12 wherein said step of performing a random code 

2 search comprises the step of: 

3 searching available codes for an improved code. 

1 14. The method of claim 12 wherein said step of performing a random code 

2 search comprises the step of: 

3 searching a subset of available codes for the best code in said subset. 

1 15. The method of claim 12 further comprising the step of: 

2 performing a gradient search of codes in the signal space area surrounding said 

3 improved code. 

1 16. The method of claim 12 further comprising the step of: 

2 performing a gradient search of transmission delays for said improved code. 

1 17. The method of claim 12 further comprising the steps of: 

2 performing a gradient search of codes in the signal space area surrounding said 

3 improved code; and 

4 performing a gradient search of transmission delays for said improved code. 

1 1 8. A method for use in a CDMA wireless communication system comprising the 

2 steps of: 

3 receiving channel characteristics of a plurality of wireless channels; and 

4 assigning codes to a plurality of wireless terminals based on said received channel 

5 characteristics. 
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1 19. The method of claim 18 wherein said step of assigning codes comprises the 

2 steps of: 

3 choosing a target wireless terminal; and 

4 assigning a code to said target wireless terminal. 

1 20. The method of claim 19 wherein step of assigning a code to a target wireless 

2 terminal comprises the step of: 

3 performing a random code search to obtain an improved code for said target 

4 wireless terminal which is an improvement over a current code of said target wireless 

5 terminal 

1 21. The method of claim 20 wherein said step of performing a random code 

il 2 search comprises the step of randomly searching available codes until an improved code 

3 is found. 

1 22. The method ofclaim 20 wherein said step of performing a random code 

I'i 2 search comprises the step of randomly searching a subset of available codes for the best 

1^ 3 code in said siibset. 

1 23. The method of claim 20 fiirther comprising the step of: 

2 performing a gradient search of codes in the signal space area surrounding said 

3 improved code, 

1 24. The method ofclaim 20 further comprising the step of: 

2 performing a gradient search of transmission delays for said improved code. 

1 25. The method of claim 20 further comprising the steps of: 

2 performing a gradient search of codes in the signal space area surrounding said 

3 improved code; and 
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4 performing a gradient search of transmission delays for said improved code. 

1 26. The method of claim 1 8 further comprising the steps of: 

2 maintaining a processing set of said plurality of wireless terminals; 

3 individually assigning codes to said wireless terminals in said processing set; and 

4 adding a wireless terminal to said processing set when said step of individually 

5 assigning codes to said wireless terminals in said processing set has converged and 

6 repeating said step of individually assigning codes. 

1 27. The method of claim 18 further comprising the step of: 

2 transmitting said codes to said plurality of wireless terminals. 

1 28. Apparatus for conmiunicating with a plurality of wireless terminals via a 

2 plurality of chaimels, said apparatus comprising: 

3 a channel estimator for determining chaimel characteristics; and 

4 a code optimizer for assigning codes to said plurality of wireless terminals based 

5 on said chaimel characteristics. 

1 29. The apparatus of claim 28 wherein said code optimizer comprises: 

2 a memory storing computer program instructions; 

3 a processor for executing said stored computer program instructions; 

4 said computer program instructions defining the steps of: 

5 choosing a target wireless terminal; and 

6 assigning a code to said target wireless terminal. 

1 30. The apparatus of claim 29 wherein the computer program instructions 

2 defining the step of assigning a code to a target wireless terminal further define the step 

3 of: 
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4 performing a random code search to obtain an improved code for said target 

5 wireless terminal which is an improvement over a current code of said target wireless 

6 terminal. 

1 31. The apparatus of claim 30 wherein said computer program instructions 

2 defining the step of performing a random code search further define the step of randomly 

3 searching available codes until an improved code is found. 

1 32. The apparatus of claim 30 wherein said computer program instructions 

2 defining the step of performing a random code search further define the step of randomly 

3 searching a subset of available codes for the best code in said subset. 

B 1 33. The apparatus of claim 3 0 wherein said computer program instructions 

in. 2 further define the step of: 

^t! 3 performing a gradient search of codes in the signal space area surrounding said 

01 4 improved code. 

1 34. The apparatus of claim 30 wherein said computer program instructions 

2 further define the step of: 

2 3 performing a gradient search of transmission delays for said improved code. 

1 35. The apparatus of claim 30 wherein said computer program instructions 

2 further define the steps of: 

3 performing a gradient search of codes in the signal space area surrounding said 

4 improved code; and 

5 performing a gradient search of transmission delays for said improved code. 

1 36. The apparatus of claim 28 wherein said computer program instructions 

2 further define the steps of: 

3 maintaining a processing set of said plurality of wireless terminals; 
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4 individually assigning codes to said wireless terminals in said processing set; and 

5 adding one of said plurality of wireless terminals to said processing set when said 

6 step of individually assigning codes to said wireless terminals in said processing set has 

7 converged and repeating said step of individually assigning codes. 

1 37. The apparatus of claim 28 wherein said computer program instructions 

2 further define the step of: 

3 transmitting said codes to said plurality of wireless terminals. 

1 38. Apparatus for commimicating with a plurality of v^reless terminals via a 

2 plurality of chaimels, said apparatus comprising: 

3 means for determining channel characteristics; and 

4 means for assigning codes to said plurality of wireless terminals based on said 

5 channel characteristics. 

1 39. The apparatus of claim 38 wherein said means for assigning codes comprises: 

2 means for choosing a target wireless terminal; and 

3 means for assigning a code to said target wireless terminal. 

1 40. The apparatus of claim 39 wherein said means for assigning a code to a target 

2 wireless terminal comprises: 

3 means for performing a random code search to obtain an improved code for said 

4 target wireless terminal which is an improvement over a current code of said target 

5 wireless terminal. 

1 41 . The apparatus of claim 40 wherein said means for performing a random code 

2 search comprises means for randomly searching available codes mtil an improved code 

3 is found. 
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1 42. The apparatus of claim 40 wherein said means for performing a random code 

2 search comprises means for randomly searching a subset of available codes for the best 

3 code in said subset, 

1 43. The apparatus of claim 40 further comprising: 

2 means for performing a gradient search of codes in the signal space area 

3 surrounding said improved code. 

1 44. The apparatus of claim 40 further comprising: 

2 means for performing a gradient search of transmission delays for said improved 

3 code. 

In 1 45. The apparatus of claim 40 further comprising: 

2 means for performing a gradient search of codes in the signal space area 

^ 3 surrounding said improved code; and 

4 means for performing a gradient search of transmission delays for said improved 

5 code. 

1 46. The apparatus of claim 38 further comprising: 

2 means for maintaining a processing set of said plxirality of wireless terminals; 

3 means for individually assigning codes to said wireless terminals in said 

4 processing set; 

5 means for adding one of said plurality of wireless terminals to said processing set 

6 when said step of individually assigning codes to said wireless terminals in said 

7 processing set has converged and repeating said step of individually assigning codes. 

1 47, The apparatus of claim 38 further comprising: 

2 means for transmitting said codes to said plurality of wireless terminals. 
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Abstract of the Disclosure 

A CDMA wireless communication system for communicating with wireless 
terminals. The system comprises a channel estimator for determining characteristics of 
the wireless channels of the wireless terminals. The channel characteristics are used by a 
code optimizer to assign spreading codes to the wireless terminals. In one embodiment, 
the code optimizer utilizes an iterative code optimization algorithm and maintains a 
processing set of wireless terminals. The code optimizer chooses target wireless 
terminals and performs a random code search in order to find an improved code for the 
target wireless terminal. The improved code found in the random code search is further 
improved by performing a gradient search of codes in the signal space in the vicinity of 
the improved code and by performing a gradient search of transmission delays. The 
improved codes are transmitted to the wireless terminals for use in reverse link 
communication. 
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IN THE UNITED STATES 
PATENT AND TRADEMARK OFFICE 

Declaration and Power of Attorney 



As a below named inventor, I hereby declare that: 

My residence, post office address and citizenship are as stated below next to my 
name. 

I hereby claim the benefit under Title 35, United States Code, 1 19(e) of any United 
States provisional application(s) identified below: 

Provisional application No. 60/137462, filed on June 4, 1999. 

I believe I am an original, first and joint inventor of the subject matter which is 
claimed and for which a patent is sought on the invention entitled Code Assignment In 
A CDMA Wireless System the specification of which is attached hereto. 

I hereby state that I have reviewed and understand the contents of the above 
identified specification, including the claims, as amended by an amendment, if any, 
specifically referred to in this oath or declaration. 

I acknowledge the duty to disclose all information known to me which is material to 
patentability as defined in Title 37, Code of Federal Regulations, 1.56. 

I hereby claim foreign priority benefits under Title 35, United States Code, 119 of 
any foreign application(s) for patent or inventor's certificate listed below and have also 
identified below any foreign application for patent or inventor's certificate having a filing 
date before that of the application on which priority is claimed: 

None 

I hereby claim the benefit under Title 35, United States Code, 120 of any United 
States application(s) listed below and, insofar as the subject matter of each of the claims 
of this application is not disclosed in the prior United States application in the manner 
provided by the first paragraph of Title 35, United States Code, 112, 1 acknowledge the 
duty to disclose all information known to me to be material to patentability as defined in 
Title 37, Code of Federal Regulations, 1.56 which became available between the filing 
date of the prior appUcation and the national or PCT international filing date of this 
application: 

None 



I hereby declare that all statements made herein of my own knowledge are true and 
that all statements made on information and belief are believed to be true; and further that 
these statements were made with the knowledge that willful false statements and the like 
so made are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 
of the United States Code and that such willful false statements may jeopardize the 
validity of the application or any patent issued thereon. 
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I hereby appoint the following attomey(s) with full power of substitution and 
revocation, to prosecute said application, to make alterations and amendments therein, to 
receive the patent, and to transact all business in the Patent and Trademark Office 
connected therewith: 



Thomas J. Bean (Reg. No. P-44528) 

Lester H. Bimbaum (Reg. No. 25830) 

Richard J. Botos (Reg. No. 3201 6) 

Jeffery J. Brosemer (Reg. No. 36096) 

Kenneth M. Brown (Reg. No. 37590) 

Craig J. Cox (Reg. No. 39643) 

Donald P. Dinella (Reg. No. 39961) 

Guy H. Eriksen (Reg. No. 4 1736) 

Martm I. Finston (Reg. No. 31613) 

James H. Fox (Reg. No. 29379) 

William S. Francos (Reg. No. 38456) 

Barry H. Freedman (Reg. No. 26166) 

Juho A. Garceran (Reg. No. 37 1 3 8) 

Mony R. Ghose (Reg. No. 38159) 

Jimmy Goo (Reg. No. 36528) 

Anthony Grillo (Reg. No. 36535) 

Stephen M. Gurey (Reg. No. 27336) 

John M. Harman (Reg. No. 38173) 

John W. Hayes (Reg. No. 33900) 

Michael B. Johannesen (Reg. No. 35557) 

Mark A. Kurisko (Reg. No. 38944) 

Irena Lager (Reg. No. 39260) 
Christopher N. Malvone (Reg. No. 34866) 

Scott W. McLellan (Reg. No. 30776) 

Martin G. Meder (Reg. No. 34674) 

John C. Moran (Reg. No. 30782) 

Michael A. Morra (Reg. No. 28975) 

Gregory J. Murgia (Reg. No. 4 1209) 

Claude R. Narcisse (Reg. No. 38979) 

Joseph J. Opalach (Reg. No. 36229) 

Neil R. Ormos (Reg. No. 35309) 

Eugen E. Pacher (Reg. No. 29964) 

Jack R. Penrod (Reg. No. 3 1 864) 

Daniel J. Piotrowski (Reg. No. 42079) 

Gregory C. Ranieri (Reg. No. 29695) 

Scott J. Rittman (Reg. No. 39010) 

Eugene J. Rosenthal (Reg. No. 36658) 

Bruce S. Schneider (Reg. No. 27949) 

Ronald D. Slusky (Reg. No. 26585) 

David L. Smith (Reg. No. 30592) 

Patricia A. Verlangieri (Reg. No. 42201) 

John P. Veschi (Reg. No. 39058) 

David Volejnicek (Reg. No. 29355) 

Charles L. Warren (Reg. No. 27407) 

Jeffrey M. Weinick (Reg. No. 36304) 

Eli Weiss (Reg. No. 17765) 
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Please address all correspondence to the Docket Administrator (Rm. 3C-512), 
Lucent Technologies Inc., 600 Mountain Avenue, P. O. Box 636, Murray Hill, New 
Jersey 07974-0636. Telephone calls should be made to Jeffrey M. Weinick by dialing 
908-582-2188. 



Full name of 1st joint inventor: Jiunn-Tsair Chen 



Inventor's signature. 




Residence: Taipei, Taiwan 106 
Citizenship: Taiwan, Republic of China 



Post Office Address: 



Box 90-3 

Taipei, Taiwan 106 
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Full name of 2nd joint inventor: Gerard Joseph Foschini 

Inventor's 'signature. ^LcA^ ^ J*^i^ ^t^^^ — ' Datej/flZ£I_ 

Residence: Sayerville, NJ, Middlesex County, New Jersey 

Citizenship: United States of America 

Post Office Address: 79 Orchard Street 

South Amboy, NJ 08879, New Jersey 08879 
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Full name of 3rd joint inventor: Constantinos Basil Papadias 

Inventor's signature ^^^Kz J^sXt 0^/g$/9 S 

Residence: Madison, Morris County, New Jersey 
Citizenship: Greece 

Post Office Address: 54 Greenwood Avenue 

Madison, New Jersey 07940 



